

FIG. 1



| UNIT  |                                                           | REGISTER FILE ACCESS                 |                         |  |  |
|-------|-----------------------------------------------------------|--------------------------------------|-------------------------|--|--|
| GROUP | OPERATIONS                                                | PRIMARY<br>DATAPATH                  | ALTERNATIVE<br>DATAPATH |  |  |
| A     | GENERAL ARITHMETIC BOOLEAN AND CONTROL REGISTER ACCESS    | R/W                                  | R                       |  |  |
| С     | - COMPARE, SHIFT, BOOLEAN<br>- ARITHMETIC: ADD, SUB       | R/W                                  | R                       |  |  |
| S     | -SHIFT, ROTATE, EXTENDED BOOLEAN<br>-ARITHMETIC: ADD, SUB | R/W                                  | R                       |  |  |
| М     | - MULTIPLY<br>- ARTHMETIC: ADD, SUB                       | R/W                                  | R                       |  |  |
| D     | - LOAD<br>- STORE<br>- ADDRESS COMPUTATION                | W TO BOTH<br>R FROM BOTH<br>R/W BOTH |                         |  |  |
| Р     | - BRANCH                                                  | R FROM BOTH                          |                         |  |  |

FIG. 3

R=READ, W=WRITE



| STAGE | FUNCTION                                             |  |  |  |  |  |  |
|-------|------------------------------------------------------|--|--|--|--|--|--|
| F0    | SEND PC TO PROGRAM MEMORY CONTROLLER. LDIP ASSIGNED. |  |  |  |  |  |  |
| F1    | CACHE BLOCK SELECT.                                  |  |  |  |  |  |  |
| F2    | ADDRESS PHASE OF INSTRUCTION CACHE ACCESS.           |  |  |  |  |  |  |
| F3    | DATA PHASE OF INSTRUCTION CACHE ACCESS.              |  |  |  |  |  |  |
| F4    | FETCH PACKET SENT TO DSP.                            |  |  |  |  |  |  |

| STAGE | FUNCTION                                                                |
|-------|-------------------------------------------------------------------------|
| D0    | DETERMINE VALID INSTRUCTIONS IN CURRENT FETCH PACKET.                   |
| D1    | SORTS INSTRUCTIONS IN EXECUTE PACKET ACCORDING TO DESTINATION UNITS.    |
| D2    | INSTRUCTIONS SENT TO DESTINATION UNITS. CROSSPATH REGISTER READS OCCUR. |
| D3    | UNITS DECODE INSTRUCTIONS.<br>REGISTER FILE READ (2ND PHASE).           |

## FIG. 5a

FIG. 5b

| UNIT          | STAGE | FUNCTION                                                                                    |
|---------------|-------|---------------------------------------------------------------------------------------------|
| NON<br>M UNIT | E     | EXECUTION OF OPERATION BEGINS AND COMPLETES. FULL RESULT AVAILABLE AT END OF CYCLE.         |
| M UNIT        | МО    | EXECUTION OF MULTIPLY OPERATION BEGINS. (OR, NON-MULTIPLY OPERATION BEGINS AND COMPLETES.)  |
| M UNIT        | М1    | MULTIPLY OPERATION CONTINUES. (OR, NON-MULTIPLY RESULT WRITTEN TO REGISTER FILE (PHASE 1).) |
| M UNIT        | M2    | MULTIPLY OPERATION COMPLETES.                                                               |

## FIG. 5c

| STAGE | FUNCTION                                                       |
|-------|----------------------------------------------------------------|
| E     | ADDRESS GENERATION OCCURS. REGISTER FILE ACCESS FOR READ DATA. |
| LO    | LOAD ADDRESS GENERATED DURING E IS SENT TOWARDS THE DMC.       |
| L1    | ADDRESS DECODE, TC ARBITRATION, TAG COMPARES.                  |
| L2    | ADDRESS DECODE, TC ARBITRATION, TAG COMPARES.                  |
| L3    | ADDRESS PHASE OF DATA CACHE ACCESS.                            |
| L4    | DATA PHASE OF DATA CACHE ACCESS.                               |
| L5    | 64-BIT DATA SENT TO DSP.                                       |

## FIG. 5d

| STAGE | FUNCTION                                                        |
|-------|-----------------------------------------------------------------|
| E     | ADDRESS GENERATION OCCURS. REGISTER FILE ACCESS FOR WRITE DATA. |
| S0    | ADDRESS SENT TO DMC.                                            |
| S1    | ADDRESS DECODE IN DMC. WRITE DATA ALIGNMENT.                    |
| S2    | TAG COMPARE IN DMC. WRITE DATA SENT TO DMC.                     |
| S3    | ADDRESS PHASE IN DATA CACHE.                                    |
| S4    | DATA PHASE IN DATA CACHE.                                       |









| [PREDICATION REG] INSTRUCTION_MNEMONIC .UNIT-DATAPATH-CROSSPATH OP1, OP2, DST |
|-------------------------------------------------------------------------------|
| WHERE:                                                                        |
| =TO BE SCHEDULED IN PARALLEL WITH PRECEDING INSTRUCTION(S)                    |
| [PREDICATION REG] = REGISTER CONTAINING PREDICATION VALUE                     |
| .UNIT =A,C,S,M,D,P UNIT GROUPS                                                |
| DATAPATH =1 FOR DATAPATH A, 2 FOR DATAPATH B                                  |
| CROSSPATH =X IF ONE OPERAND COMES FROM OPPOSITE REGISTER FILE                 |
| OP1, OP2 =SOURCE REGISTERS                                                    |
| DST = DESTINATION REGISTER                                                    |
|                                                                               |
| UNIT ASSEMBLY NOTATIONS ASSEMBLY WITH                                         |

| UNIT  | ASSEMBLY NOTATIONS |            | ASSEMBLY            |                                         | WITH           |                                |  |
|-------|--------------------|------------|---------------------|-----------------------------------------|----------------|--------------------------------|--|
| GROUP | DATAPATH A         | DATAPATH B | E                   | EXAMPLES                                | CROSSPATH      |                                |  |
| Α     | .A1                | .A2        | ADD<br>SUB          | .A1 A1,A2,A3<br>.A2 B1,B2,B3            | ADD<br>SUB     | .A1X A1,B2,A3<br>.A2X B1,A2,B3 |  |
| С     | .C1                | .C2        |                     | .C1 A1,A2,A3<br>.C2 B1,B2,B3            | CMPEQ<br>CMPEQ | .C1X A1,B2,A3<br>.C2X B1,A2,B3 |  |
| S     | .S1                | .S2        | SHL<br>SHL          | .S1 A1,A2,A3<br>.S2 B1,B2,B3            | SHL<br>SHL     | .S1X A1,B2,A3<br>.S2X B1,A2,B3 |  |
| М     | .M1                | .M2        | MPY<br>MPY          | .M1 A1,A2,A3<br>.M2 B1,B2,B3            | MPY<br>MPY     | .M1X A1,B2,A3<br>.M2X B1,A2,B3 |  |
| D     | .D                 |            | LDB<br>STB<br>ADDAH | .D *A8,A12<br>.D A8,*A12<br>.D A8,A2,B1 | n/a            |                                |  |
| Р     |                    | Р          | В                   | A8                                      |                | n/a                            |  |

























FIG. 20

|                  |                 | SOURCE(S) DATA PATH |            |            |             |              |             |  |  |
|------------------|-----------------|---------------------|------------|------------|-------------|--------------|-------------|--|--|
|                  |                 | A,C,S               | M<br>(ADD) | M<br>(MUL) | D<br>(LOAD) | D<br>(STORE) | D<br>(ADDR) |  |  |
|                  | A,C,S           | 0                   | 1          | 3          | 7           | _            | 1           |  |  |
|                  | М               | 1                   | 1          | 3          | 7           | -            | 1           |  |  |
|                  | D (LOAD)        | _                   | _          | _          | _           | 0            | <u></u>     |  |  |
| SINK(S) IN       | D (STORE)       | 0                   | 0          | 2          | 6           | _            | 0           |  |  |
| SAME<br>DATAPATH | D (ADDR:BASE)   | 1                   | -          | 3          | 7           | _            | 0           |  |  |
|                  | D (ADDR:OFFSET) | 1                   | _          | 3          | 7           | _            | 1           |  |  |
|                  | Р               | 0                   | 1          | 3          | 7           | _            | 1           |  |  |
|                  | PREDICATION     | 0                   | _          | 2          | 6           | _            | 0           |  |  |
| SINK(S) IN       | A,C,S           | 1                   | 2          | 4          | 8           | _            | 2           |  |  |
| OPPOSITE         | М               | 1                   | 2          | 4          | 8           | _            | 2           |  |  |
| DATAPATH         | PREDICATION     | 0                   | _          | 2          | 6           | _            | 0           |  |  |

FIG. 21







READ PHASE WRITE PHASE

INSTRUCTION 1 ADD REG1, REG2, REG3
INSTRUCTION 2 ADD REG3, REG4, REG5

HOTPATH AVAILABLE

ZERO DELAY SLOTS

CPU CYCLE 0 CPU CYCLE 1 CPU CYCLE 2 CPU CYCLE 3 CPU CYCLE 4







